return GTK_ACCESSIBLE_GET_IFACE (self)->get_platform_state (self, state);
}
+/*<private>
+ * gtk_accessible_bounds_changed:
+ * @self: a #GtkAccessible
+ *
+ * This function can be used to inform ATs that an
+ * accessibles bounds (ie its screen extents) have
+ * changed.
+ *
+ * Note that the bounds are not included in this API.
+ * AT backends should use widget API to obtain them.
+ */
+void
+gtk_accessible_bounds_changed (GtkAccessible *self)
+{
+ GtkATContext *context;
+
+ if (GTK_IS_WIDGET (self) &&
+ gtk_widget_get_root (GTK_WIDGET (self)) == NULL)
+ return;
+
+ context = gtk_accessible_get_at_context (self);
+ if (context == NULL)
+ return;
+
+ gtk_at_context_bounds_changed (context);
+}
+
/*<private>
* gtk_accessible_should_present:
* @self: a #GtkAccessible
gboolean gtk_accessible_get_platform_state (GtkAccessible *self,
GtkAccessiblePlatformState state);
+void gtk_accessible_bounds_changed (GtkAccessible *self);
+
G_END_DECLS
{
}
+static void
+gtk_at_context_real_bounds_change (GtkATContext *self)
+{
+}
+
static void
gtk_at_context_class_init (GtkATContextClass *klass)
{
klass->state_change = gtk_at_context_real_state_change;
klass->platform_change = gtk_at_context_real_platform_change;
+ klass->bounds_change = gtk_at_context_real_bounds_change;
/**
* GtkATContext:accessible-role:
{
GTK_AT_CONTEXT_GET_CLASS (self)->platform_change (self, change);
}
+
+void
+gtk_at_context_bounds_changed (GtkATContext *self)
+{
+ GTK_AT_CONTEXT_GET_CLASS (self)->bounds_change (self);
+}
void (* platform_change) (GtkATContext *self,
GtkAccessiblePlatformChange changed_platform);
+
+ void (* bounds_change) (GtkATContext *self);
};
GdkDisplay * gtk_at_context_get_display (GtkATContext *self);
void gtk_at_context_platform_changed (GtkATContext *self,
GtkAccessiblePlatformChange change);
+void gtk_at_context_bounds_changed (GtkATContext *self);
const char * gtk_accessible_property_get_attribute_name (GtkAccessibleProperty property);
const char * gtk_accessible_relation_get_attribute_name (GtkAccessibleRelation relation);